Skip to content

Conversation

@Ralith
Copy link
Collaborator

@Ralith Ralith commented May 23, 2024

This is a breaking change with no pressing demand.

@Ralith Ralith changed the title Variable length cids Variable length connection IDs May 23, 2024
..
} = incoming.packet.header;

if self.cids_exhausted() {
Copy link
Contributor

@thynson thynson May 23, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

One option is, changing return type of the ConnectionIdGenerator.generate_cid to Result<ConnectionId, SomeError>, so that if the implementation of ConnectionIdGenerator is willing to perform exhausted check, it could return an Err(CidExhausted). But since it must be a breaking change, I'm not sure if it's worth to do it in this way.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

These changes are breaking regardless, so we might as well take the cleanest approach. However:

  • The generator would need to know the total number of live CIDs, requiring additional complexity
  • Large deployments might have a difficult time tracking the number of CIDs in use in a shared space across multiple endpoints
  • It's not clear if this check is all that useful to begin with

I'm presently leaning towards a simpler approach that just gives up if it can't generate a unique CID after some number of tries, to at least handle the case where someone is using an extremely small CID space for some reason.

@Ralith Ralith force-pushed the variable-length-cids branch from 7479835 to 2757df1 Compare May 25, 2024 20:39
@Ralith Ralith marked this pull request as ready for review May 25, 2024 20:39
@Ralith Ralith force-pushed the variable-length-cids branch 6 times, most recently from 077fa06 to 5ceba42 Compare May 25, 2024 21:11
@djc djc added the breaking label May 28, 2024
Ralith added 9 commits June 2, 2024 11:24
Allows generators to be shared with connections, and removes an
obstacle to parallelizing endpoint work in the future.
Now that CID generators can have shared ownership, there's no need to
indirect through a factory function in the config.
We can't track this if the size of the CID space isn't readily known,
and we already implicitly rely on `new_cid` being infallible.
@Ralith Ralith force-pushed the variable-length-cids branch from 5ceba42 to 615a1ed Compare June 2, 2024 18:24
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants